<template>
    <div class="user-edit-container">
      <!-- Header 区域 -->
      <van-nav-bar title="编辑资料" left-arrow @click-left="$router.back()" fixed />

      <!-- 用户资料 -->
      <van-cell-group class="action-card">
        <van-cell title="头像" is-link center>
          <template #default>
            <van-image round class="avatar" :src="profile.photo" @click="$refs.iptFile.click()"/>
            <input type="file"
            ref="iptFile"
            v-show="false"
            accept="image/*"
            @change="onFileChange">
            <!-- accept表示支持的格式 -->
          </template>
        </van-cell>
        <van-cell title="名称" is-link  :value="profile.name" @click="showNameDialogFn"/>
        <!-- 修改用户名称的对话框 -->
        <van-dialog
            v-model="isShowNameDialog"
            title="修改名称"
            show-cancel-button
            :before-close="onNameDialogBeforeClose">
            <!-- 输入框 -->
            <van-field
                v-model.trim="userName"
                input-align="center"
                maxlength="7"
                placeholder="请输入名称"
                v-fofo
            />
        </van-dialog>
        <!-- 修改时间 -->
        <van-popup v-model="isShowBirth" position="bottom" style="height: 50%" round>
              <!-- 日期选择控件 -->
              <van-datetime-picker
                v-model="currentDate"
                type="date"
                title="选择出生日期"
                :min-date="minDate"
                :max-date="maxDate"
                :show-toolbar="true"
                @cancel = 'isShowBirth = false'
                @confirm = 'confirmFn'
              />
        </van-popup>
        <van-cell title="生日" is-link  :value="profile.birthday" @click="isShowBirth = true"/>
      </van-cell-group>
    </div>
  </template>

<script>
import { userProfileAPI, updatePhotoAPI, updateProfileAPI } from '@/api'
import { Notify } from 'vant'
import moment from 'moment'
export default {
  name: 'UserEdit',
  data () {
    return {
      profile: {}, // 用户基本资料
      isShowNameDialog: false, // 是否显示姓名弹出框
      userName: '', // 编辑用户姓名
      isShowBirth: false, // 显示时间选择器
      minDate: new Date(1900, 0, 1),
      maxDate: new Date(),
      currentDate: new Date() // 当前日期
    }
  },
  async created () {
    const res = await userProfileAPI()
    console.log(res)
    this.profile = res.data.data
  },
  methods: {
    // 文件选择方法
    async onFileChange (ev) {
      // console.log(ev.target.files[0]) // ev.target.files 上传文件的集合,选择第一个做滤空判断
      if (ev.target.files.length === 0) return // 防止用户未选择图片
      const fd = new FormData()
      fd.append('photo', ev.target.files[0]) // photo表单里参数名携带
      const res = await updatePhotoAPI(fd)
      console.log(res)
      this.profile.photo = res.data.data.photo // 更新最新头像
    },
    // 点击名字出现弹出框
    showNameDialogFn () {
      this.isShowNameDialog = true
      this.userName = this.profile.name
    },
    // 姓名修改弹出层-关闭前方法
    // 姓名修改弹出层-关闭前方法
    async onNameDialogBeforeClose (action, done) {
    // action的值: confirm或cancel(点击按钮区分)
      if (action === 'confirm') {
        // 确定
        // unicode编码 \u4092
        // url编码 %E2%C3%D1
        if (/^[A-Za-z0-9\u4e00-\u9fa5]{1,7}$/.test(this.userName)) {
          // 通过校验
          // 调用接口
          await updateProfileAPI({
            username: this.username
          })
          // 更新页面显示的名字
          this.profile.name = this.userName
          // 关闭弹窗
          done()
        } else {
          // 提示用户
          Notify({ type: 'warning', message: '用户名中英文和数字1-7位' })
          // 阻止弹窗关闭
          done(false)
        }
      } else if (action === 'cancel') {
        // 取消
        done()
      }
    },
    // 弹出时间选择框
    showBirthFn () {
      this.isShowBirth = true
      this.currentDate = new Date(this.profile.birthday)
    },
    // 时间选择
    async confirmFn () {
      const datestr = moment(this.currentDate).format('YYYY-MM-DD')
      await updateProfileAPI({
        birthday: datestr
      })
      this.profile.birthday = datestr
      // 关闭时间选择器
      this.isShowBirth = false
    }
  }
}
</script>

  <style lang="less" scoped>
  .user-edit-container {
    padding-top: 46px;
    .avatar {
      width: 50px;
      height: 50px;
    }
  }
  </style>
